<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>非组件之间的通信</title>
    <script src="https://cdn.staticfile.org/vue/2.6.11/vue.js"></script>
</head>
<body>
<div id="case13-demo6">
    <a-component></a-component>
    <b-component></b-component>
</div>
<script type="text/javascript">
    var case13Demo6=new Vue({
        el:"#case13-demo6",
        data:{
            bus:new Vue()
        },
        components:{
            'a-component':{
                template:`
                <div>
                    <button v-on:click="handle">点击我想B组件传递数据</button>
                </div>`,
                data: function () {
                    return{
                        msg:"我是来自A组件的内容"
                    }
                },
                methods:{
                    handle:function () {
                        this.$root.bus.$emit("pass1",this.msg)
                    }
                }
            },
            'b-component':{
                template: '<div></div>',
                created:function () {
                    //A组件在实例创建的时候就监听事件-pass事件
                    this.$root.bus.$on("pass1",function (value) {
                        alert(value)
                    })
                }
            }
        }
    })
</script>
</body>
</html>